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© A method and system for synchronizing threads within a process. 



© A method and system is described for synchro- 
nizing execution by a processing element of threads 
within a process. Before execution of a thread com- 
mences, a determination is made as to whether all of 
the required resources for execution of the thread 
are available in a cache local to the processing 
element. If the resources are not available, then the 
resources are fetched from main storage and stored 
in one or more local caches before execution begins. 
If the resources are available, then execution of the 
thread may begin. During execution of the thread 
and. in particular, an instruction within the thread, the 
instruction may require data in order to successfully 



complete its execution. When this occurs, a deter- 
mination is made as to whether the necessary data 
is available. If the data is available, the result of the 
instruction execution is stored and execution of the 
thread continues. However, if the data is unavailable, 
then the thread is deferred until the data becomes 
available and a new thread is processed. When 
deferring <a thread, the thread is placed in the mem- 
ory location which is io receive the required data. 
Once the data is available, the thread is removed 
from the data location and placed on a queue for 
execution and the data is stored in the location. 
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TECHNICAL FIELD 

This invention relates in general to data syn- 
chron^t on within a parallel data P^ess,ng sys- 
JeTand more particularly to the synchrony of 

threads within a process being executed by a pro- 

cessing element. 

BACKGROUND ART 

,n parallel data processing systems, programs 
to be executed may be divided into a number of 
processes which may be 

c uSs a group of sequentially executable .nstruc- 
tons The simu.taneous execution of a numbe of 
Teads requires synchronization or 
tion of the activities assoc.ated w.th each threap 
Without synchronization a proce ^ * 
, or a great deal of time wa.t.ng for data .t requ es. 
thereby degrading system performance and ut.l.za 

^ A thread located in one process is capable of 
communing with threads in another process^ 
in the same process and therefore, various levels 
of synchronization are requ.red in order tc > have > an 
efficiently executing system with a high degree of 

^To^lrtr^chronize the communication of 
threads located in different processes, a synchro- 
nizafon mechanism, such as. .-structures may be 
used, l-structures are used in main storage and are 
described in .-structures: Data Structures for P* 
a „e. Computing by Arvind. R.S^ NAM .ml K£ 
Pinga.i. Massachusetts .nstitute of Techno^gy Lab 
oratory for Computer Science. February 1987. 

Synchronization of threads communing be- 
tween different processes does not negate the 
need for a synchronization mechanism used to 
synchronize threads within the same process. 
There ore a need still exists for an efficient manner 
to synchronize threads within a process : thereby 
M inn nreater system utilization and perfor- 
nTnce 9 A 9 neeTa.so exists .or a synchronization 
Tchanism of threads within a process ^ramfre 
synchronization mechanism .s local to the process 
fng element in which the threads are executed^ A 
further need exists for a synchronizat.cn mecha- 
nism which does not place a constant on the 
number of processes and threads which may be 
executed by the processing element due to the 
size of local memory. 



DISCLOSURE OF INVENTION 

The shortcomings of the prior art « > overcome 
and additional advantages are prov.ded .n accor 



dance with the principles of the present invention 
Sough the provision of a method and system for 
synchronizing threads within a process. 

Z accordance with the principles of the present 
s invention, a method for synchronizing execut.on by 
a processing element of threads within a process ,s 
prided. The process includes fetching dun*~ 
ecution of a thread within a process a datum f eld 
Tom a local frame cache and an assocated state 
ndTcator from a state bit cache. The state .nd.cator 
has a Lt state value which is used to determine 
whether the datum field includes a datum available 
Tor use by the thread. If the datum .s unava labl* 
Sen execution of the thread is deferred until the 

75 Embodiment, the thread is represented 

bv a continuation descriptor and the step of de er- 
ring the thread includes storing the cont.nuat.on 
descriptor within the datum f.eld. 

in vet another embodiment, the method of syn- 
20 chroniz ng threads includes awakening the deferred 
'hread when the datum is available for the thread. 
Awakening includes removing the cont.nuat.on de- 
btors stored in the datum field and then placing 

9<; the datum in the field. 

in another aspect of the invention, a system fo 
synchronizing execution by a ^ 
oi threads within a process .s P/^ J^, 
t em includes a local frame cache and a state bit 
30 cache, means for executing by the P^"*^ 
ment a thread within a process and means for 
Tetching from the local frame cache a da urn f e d 
and from the state bit cache an assoc.ated state 
fnd'catoT The state indicator has a first state value 
■nd me system inc.udes means for determin.ng 
" based on S first state value whether the datum 
^e d includes a datum available for use by the 
h ead Should the datum be unava..able then 
means £ deferring execution of the thread unt.l 
the datum is available is provided. 
° Tone embodiment, the system further .n- 

Cudes means for determining a second stete ter 
L state indicator wherein the second state wfl 
eolace the first state during execufon of the 
<s h^ad The first state may indicate a current state 

" and me second state may ^^^nTmemod for 
,n another aspect of the invention, a m^fo 
synchronizing execution by a process.ng , element 
oi threads within a process .s prov.ded. Each 
™ thread includes a plurality of instructions and the 
50 method Tncludes executing an instruction. Dur.ng 
execution of the instruction, at least one source 
operand is fetched from a local frame cache and at 
teast one corresponding state indicator hav.ng a 
ss £sf stete is fetched from a state bit cache. A so 
fetched from the instruction is at least one state 
function associated with at least one fetehed 
source operand. The state function .s used to se- 
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lect from one of a plurality of tables N possible 
second states for the state indicator wherein each 
of the second states has an associated flag indica- 
tor. The first state is used to choose from the 
selected N possible states a second state for the 5 
state indicator and the second state replaces the 
first state during thread execution. The flag indica- 
tor specifies one of a plurality of actions for the 
thread to perform. 

In accordance with the principles of the present io 
invention, a method and system for synchronizing 
threads within a process is provided. The synchro- 
nization mechanism of the present invention sus- 
pends execution of a thread when data for that 
thread is unavailable thereby allowing another is 
thread to be executed. This provides for increased 
system utilization and system performance. 

BRIEF DESCRIPTION OF DRAWINGS 

20 

The subject matter which is regarded as the 
invention is particularly pointed out and distinctly 
claimed in the claims at the conclusion of the 
specification. The foregoing and other objects, fea- 
tures and advantages of the invention will be ap- 25 
parent from the following detailed description taken 
in conjunction with the accompanying drawings in 
which: 
FIG. 1 

depicts one example of a block diagram of a 30 
parallel processing system, in accordance with 
the principles of the present invention; 
FIG. 2 

is one example of the logical components asso- 
ciated with a main memory control unit of the as 
parallel processing system of FIG. 1, in accor- 
dance with the principles of the present inven- 
tion; 
FIG. 3 

is an illustration of one embodiment of a logical 40 
local frame residing in the main memory control 
unit of FIG. 2, in accordance with the principles 
of the present invention; 
FIG. 3a 

depicts one example of a logical work frame 45 
associated with the local frame of FIG. 3, in 
accordance with the principles of the present 
invention; 
FIG. 3b 

illustrates one embodiment of the fields con- so 
tained within a non-compressed continuation de- 
scriptor of the present invention; 
FIG. 4 

is an illustration of one embodiment of the en- 
tries of a logical code frame residing in main 55 
memory control units of FIG. 2, in accordance 
with the principles of the present invention; 
FIG. 4a 



depicts one example of the fields within an 
instruction located in the code frame of FIG. 4, 
in accordance with the principles of the present 
invention; 
FIG. 4b 

depicts one example of the components of the 
destination and source specifiers of the instruc- 
tion of FIG. 4a. in accordance with the principles 
of the present invention; 
FIG. 5 

illustrates one embodiment of a block diagram 
of the hardware components of a processing 
element of FIG. 1 . in accordance with the princi- 
ples of the present invention; 
FIG. 6 

depicts one example of the components of a 
ready queue entry within a ready queue de- 
picted in FIG. 5. in accordance with the princi- 
ples of the present invention; 
FIG. 7. 

is one example of the components of a local 
continuation queue within the processing ele- 
ment of FIG. 5, in accordance with the principles 
of the present invention; 
FIG. 8 

illustrates one example of a block diagram of the 
components associated with a code frame 
cache residing within the processing element of 
the present invention; 
FIG. 9 

depicts one example of a code frame cache 
directory associated with the code frame cache 
of FIG. 8, in accordance with the principles of 
the present invention; 
FIGS. 10a, 10b 

depict one example of a block diagram of the 
components associated with a local frame cache 
located within the processing element depicted 
in FIG. 5, in accordance with the principles of 
the present invention; 
FIG. 11 

depicts one example of a local frame cache 
directory associated with the local frame cache 
of FIGS. 10a, 10b, in accordance with the princi- 
ples of the present invention; 
FIGS. 12a. 12b 

depict one example of a flow diagram of the 
synchronization process of the present inven- 
tion; and 
FIG. 13 

depicts one example of a flow diagram of the 
processes associated with writing data to a loca- 
tion in a cache, in accordance with the princi- 
ples of the present invention. 
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BE ST MODE FOR CARRYING OUT THE INVEN- 
TION 

The synchronization mechanism of the present 
invention resides within a parallel data processing 5 
system 10. as depicted in FIG. 1. In one embodi- 
ment, parallel data processing system 10 includes 
one or more main memory control units 12, a 
plurality of processing elements (PE) 14 and a 
plurality of input/output processors (l/OP) 16. Pro- w 
cessing elements 14 communicate with each other, 
main memory control units 12 and input/output 
processors 16 through an interconnection network 
18. One example of the main components asso- 
ciated with main memory control units 12 (or main is 
storage) and processing elements 14 are explained 
in detail below. 

Each of main memory control units 12 contains 
a portion of a sequentially addressed linear mem- 
ory address space (not shown). The basic unit of 20 
information stored in the address space is a word 
(or memory location) having a unique address 
across all main memory control units. Contiguous 
words or memory locations may be combined into 
a logical structure such as a local frame 20 (FIG. 25 
2), a code frame 22 and a work frame 23. In one 
embodiment, local frame 20 and work frame 23 
generally refer to a group of data words and code 
frame 22 refers to a group of instructions. There 
may be a plurality of local frames, work frames and 30 
code frames within main memory control units 12. 
In one embodiment, a particular local frame is 
associated with a process such that the address of 
a local frame is used as the identifier of a process. 

Referring to FIG. 3, local frame 20 has, in one 35 
example, 256 local frame locations 24. The first 
four locations are reserved for an invocation con- 
text map entry 26. which is associated with a 
process to be executed by one of processing ele- 
ments 14, the next two slots are reserved for 40 
functions not discussed herein and the remainder 
of the locations (six through 255) are reserved for 
data local to the process. The information con- 
tained within invocation context map entry 26 is 
established prior to instantiation of the process and 45 
includes, for instance, the following fields: 

(a) A three bit state indicator (ST) 28 which 
indicates the current state of a local frame loca- 
tion. As described further below, state indicator 

28 is relative to a state function, which is used in so 
accessing the frame location; 

(b) A twelve bit physical processing element 
(PE) number 30 which identifies which process- 
ing element is to execute the process; 

(c) A three bit process state (PS) 32 which 55 
indicates the state of the associated process. A 
process may have any one of a number of 
states including, for example: a free state, which 



is used as a reset state to indicate that the 
process is no longer active; an inactive state, 
used to prevent a process from executing; a 
suspended state, used to prevent any modifica- 
tion to a process so that, for example, the op- 
erating system may perform a recovery; an ac- 
tive state in main storage, used to indicate that 
the process can execute and that it is main 
memory; or an active state not in main storage, 
used to indicate that the process can execute 
and it is within the processing element assigned 
to execute the process; 

(d) A two bit local frame state (FS) 34 which 
indicates the state of local frame 20. Local frame 
20 may have, as an example, one of the follow- 
ing states: 

a present state representing that the local frame 

is present in main storage; 

a transient state representing that the local 

frame is transient between main storage and 

memory local to the processing element, which 

is identified by processing element number 30; 

and 

an absent state indicating that references to 
local frame 20 are to be redirected to the pro- 
cessing element's local memory, as indicated 
by physical processing element number 30; 

(e) A one bit invocation context queue control 
(ICQC) 36 which indicates the manner in which 
the process is enqueued onto an invocation con- 
text queue (described below) at instantiation; 

(f) A one bit cache pinning control (CPC) 37 
which indicates whether a code frame or a local 
frame located within the processing element 
(e.g., within a code frame cache or a local frame 
cache, which is described below) is to be 
pinned. 

(g) An eight bit local continuation queue head 
(LCQH) pointer 38 which contains an offset into 
a first entry of work frame 23 (FIG. 2) which is in 
contiguous memory locations to local frame 20 
(described below); 

(h) An eight bit local continuation queue tail 
(LCQT) 40 which contains an offset into the first 
empty entry at the end of work frame 23; 

(i) A forty bit invocation context queue (ICQ) 
forward pointer 42 which is used in creating a 
doubly linked list of processes (referred to as an 
invocation context queue) in main storage for 
the processing element identified by processing 
element number 30. The invocation context 
queue has a head and a tail which are retained 
within the processing element, and it is ordered 
based on the enqueue discipline indicated by 
invocation context queue control 36; 

(j) A forty bit invocation context queue (ICQ) 
backward pointer 44 which is also used in creat- 
ing the invocation context queue of processes; 
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and 

(k) A forty bit code frame pointer 46 which 
specifies the address of a current code frame 22 
(FIG. 2). 

As previously stated, locations six through 255 5 
of local frame 20 are reserved for data. Each data 
entry 48 includes state indicator 28 and a 64-bit 
datum field 50. Datum field 50 contains the data 
used during execution of the process. 

Referring once again to FIG. 2, coupled to w 
each local frame 20 is a logical structure referred 
to as work frame 23. Work frame 23 is allocated in 
the next 256 contiguous locations to local frame 20. 
Local frame 20 and work frame 23 are managed as 
a single entity. The first, for example, sixty-four 75 
entries or locations 52 of work frame 23 (FIG. 3a) 
include one or more compressed continuation de- 
scriptors (CCD) 54 used, as explained below, in 
selecting an instruction to be executed or data 
which is to be used by the instruction. Each com- 20 
pressed continuation descriptor 54 includes, for 
instance, a code offset 56 and an index 58 
(described below). In contrast, a continuation de- 
scriptor which is not compressed also includes a 
local frame pointer 60 (FIG. 3b), which indicates 25 
the beginning of local frame 20. A compressed 
continuation descriptor does not need to store the 
local frame pointer, since it may be inferred from 
the main storage address of the local frame/work 
frame pair. In one embodiment, each location 52 in 30 
work frame 23 is capable of storing four com- 
pressed continuation descriptors. 

Referring once again to FIG. 2, the local frame/ 
work frame pair is coupled to code frame 22 
through code frame pointer 46 of invocation context 35 
map entry 26 embedded within local frame 20. 
Code frame 22 includes, for instance, 256 code 
frame locations 62 (FIG. 4) and each location in- 
cludes a word-sized instruction 64 or an inline 
constant (not shown), which is associated with the 40 
process to be executed by processing element 14 
as indicated by processing element number 30. 
Subsequent to loading the instructions or constants 
(data for constants are stored at code frame gen- 
eration) into the code frame, the code frame is 45 
immutable and thus, may be shared by other pro- 
cesses and processing elements. In one embodi- 
ment, code frame 22 is managed in main storage 
in sequentially addressed and contiguous group- 
ings of sixteen word blocks. This allows for efficient 50 
transfer of code frames in main storage to memory 
locations local within the processing element (e.g.. 
code frame caches, which are described below). 

Referring to FIG. 4a. instruction 64 is, for in- 
stance 64 bits in length and includes the following 55 
fields: 

(a) An 8-bit instruction operation code 66 which 
specifies the operation to be executed by the 



processing element. The operation code con- 
trols the arithmetic/logical units and instruction 
sequencing. In addition, it also controls network 
request generation; 

(b) A two-bit thread control (TC) 68 which speci- 
fies the sequencing controls for the current 
thread and its successors (a process includes 
one or more threads of executable instructions) 
within the processing element in which the 
threads are being executed. The sequencing 
may be, for example, sequential instruction dis- 
patch, preventive suspensive submode or end of 
thread, each of which are described herein. 
Sequential instruction dispatch is the mode of 
execution which entails sequential dispatch of 
the instructions of a thread being executed by 
the processing element. 

Preventive suspensive submode causes suspen- 
sion of the current thread at initial dispatch into 
the processing element of an instruction within 
the thread. Should the instruction execute suc- 
cessfully, the thread is requeued in a last in-first 
out fashion onto a local continuation queue of 
the current process at code offset plus one 
(described further below). If the thread suspends 
on a source operand reference, then requeuing 
of the thread does not take place at this time 
and deferring of the thread occurs, as described 
below. Following execution of the instruction, a 
new thread is dispatched into the processing 
element. 

End of thread indicates to the processing ele- 
ment that the current thread ends after execu- 
tion of this instruction. When termination of the 
thread is detected, the processing element 
switches to the next available thread to be ex- 
ecuted. This thread may be from the same 
process or a higher priority process, which is 
enqueued LIFO (Last in-First out) after initial 
dispatch of the current process into the process- 
ing element. 

(c) A two-bit index increment control (X) 70 
which controls the increment of the value of 
index 58 (FIGS. 3a, 3b) in the current continu- 
ation descriptor. When index increment control 
70 is set to a nonzero value, index 58 is updated 
after execution of the current instruction and 
prior to execution of the succeeding instructions 
in the same thread. 

In one example, index increment control 70 may 
indicate no change in the value of index 58 from 
this instruction to the next or it may indicate the 
incremental value is plus one or minus one; 

(d) A sixteen bit destination specifier 72 is an 
address which indicates, for instance, the target 
of the instruction execution's result; and 

(e) A sixteen bit source operand 0 specifier 74 
and a sixteen bit source operand 1 specifier 76. 
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r"t^l~s ih. process*, 
element. operand 

fields, as depicted in FIG. 4b^ ?a 
/„\ a four bit addressing mode neia \« ; 

addressing is to be used, 
and the destination spec.f.er a state ,u "= 

ot synw function asso- 

SL*rihT« aval,. synchrony 
* Each sule ^■"""Jf^ 

erty. It refers »n»|j instructions; 

frame location, and the access tyu 
write as described in detail below. 
The state function field is ignored when ad- 
dressfg mode 78 selects, for example, a l.teral 

?r-?Anei a ht bit frame offset 82 interpreted as an 
Sset f to one of the accessible local frames 
££ a ,ca, frame 

fnV^^ 

dtectly or it can be initially added to the vaU.e 
o TndL 58 from the current cont.nuat.on de- 
scriptor, modulo 256. In one embedment rt .» 
"en" appended to local 
Seated by addressing mode 78 ana a kx. 
access within the local frame cache .. 



attempted under contro. of state function 80. 
described in detail below. 
"Sh coda M. a -» 

"^1:^ and*^ manned " 

S 5££ TisSit «*. mdlca.es that the coda 
cess requinng the absent coa indicates 

tTs str^eSsTn this state until the frame 
Tsno Tonger "required and it is returned to free 
, 5 storage under ^eco^ ^ 

Refemng °™;^™ io proceS sing ele- 
contro units 12 are cuuw^ /pig 

Vrac^t:™^:^^ 

- ^so^:^ 

^depote * «< incw "-a .ollo-no: » 
Tad, Q^aoa 84. a local continuation queue 86. a 
cia cache 88. a local Lama cache KLa 

- ~ » c nr;r daT~d^: 

"'ITS 'aad, queue <RQ) state 85 <«« 

Ury. Each -aady «»« ahlry im l»»"» 
TnLber ol aulas, including. *» instance. >" e 
amply, indicating thai ths ; enlryis un- 
used and available; ready, indicating thai the 
?S«Tis ready lor execution by the process- 

55 "read 9 from the process represented by »» 
ready queue entry is being executed by the 

processing element; 
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(b) A local frame pointer 96 is used, for in- 
stance, in accessing local frame cache 90. 
which as described in more detail below, in- 
cludes the data required for process execution. 

In addition, local frame pointer 96 is used in s 
determining whether a local frame exists within 
the local frame cache. Local frame pointer 96 is 
a copy of local frame pointer 60 and is loaded at 
the time that the ready queue entry is filled in; 

(c) A local frame cache physical pointer 97 is an io 
address into local frame cache 90; 

(d) A three bit local frame cache state 98 is 
used to indicate the current state of a local 
frame in local frame cache 20. A local frame 
within the local frame cache may have a number 75 
of states including, for 1 example: empty, indicat- 
ing that the frame state for that local frame is 
unknown or not present; transient, indicating the 
local frame is currently being inpaged from main 
memory control units 12 to local frame cache 90 20 
in processing element 14; and present, indicat- 
ing the local frame is located in local frame 
cache 90; 

(e) A code frame pointer 99 is used in accessing 
code frame cache 88. Code frame pointer 99 is 25 
a copy of code pointer 46 located in local frame 

20; 

(f) A code frame cache physical pointer 100 is 
used to address a block of instructions in code 
frame cache 88, as described further below; 30 

(g) A three bit code frame cache state 101 is 
used to determine the current state of a code 
frame within code frame cache 88. A code 
frame may have a number of states including, 

for example: empty, indicating that the frame 35 
state for a particular code frame is unknown or 
not present; transient, indicating the code frame 
is currently being inpaged from main memory 
control units 12 to code frame cache 88 in 
processing element 14; and present, indicating ao 
the code frame is located in code frame cache 
88. 

(h) A local continuation queue head pointer 102 
is located in each ready queue entry and is 
used, as described more fully below, in indicat- 45 
ing the head of the list of threads for the particu- 
lar process to be executed within a processing 
element. During processing, as described below, 
local continuation queue head pointer 102 re- 
ceives its information from local continuation 50 
queue head pointer 38 located within invocation 
context map entry 26 of local frame 20 which is 
associated with the process to be executed; and 

(i) AJocal continuation queue tail pointer 103 is 
located in each ready queue entry and is used, 55 
as described more fully below, in indicating the 

tail of the list of threads for the particular pro- 
cess. Similar to head pointer 102, local continu- 



ation queue tail pointer 103 is received from 
local frame 20. In particular, during enqueue into 
the ready queue, local continuation queue tail 
pointer 40 in local frame 20 is copied into ready 
queue entry 94. 
Associated with each ready queue entry 94 is a 
local continuation queue 86 (FIG. 5). Each local 
continuation queue is, for example, a first in-first 
out queue wherein the top entry in the queue is the 
oldest. In general, local continuation queue 86 con- 
tains all of the pending threads or continuations 
associated with a process which is on the ready 
queue. The local continuation queue head and tail 
pointers located in ready queue entry 94 indicate 
the valid entries in the local continuation queue for 
the particular ready queue entry. Depicted in FIG. 7 
is one example of local continuation queue 86. 

Local continuation queue 86 includes a number 
of local continuation queue entries 104. in which 
each entry represents a pending thread for a par- 
ticular process. Each local continuation queue entry 
104 contains a compressed continuation descriptor 
including a code offset 105 and an index 106, 
which are received from work frame 23 (i.e. code 
offset 56, index 58) of main memory control units 
12. Code offset 105 is used to address an instruc- 
tion within a code frame located in code frame 
cache 88 and index 106 is used during indexed 
addressing to alter the value of the address used to 
locate data within cached local frame cache 90. 

Local continuation queue 86 is coupled to code 
frame cache 88 via code frame cache physical 
pointer 100, as described in detail herein. Referring 
to FIG. 8, code frame cache 88 includes in one 
example. 128 code frames 108 and each code 
frame includes, e.g.. 256 instructions. In one em- 
bodiment, the code frames located in code frame 
cache 88 are inpaged from main memory control 
units 12 <o code frame cache 88 during a prefetch 
stage, described below. Code frame cache 88 sup- 
ports two simultaneous access ports: a read port 
used in fetching instructions and a write port used 
in writing code frames from main storage to the 
code frame cache.. 

In order to locate code frame 108, code frame 
pointer 99 located in ready queue entry 94 of 
ready queue 84 is input into a code frame cache 
directory 110 in order to obtain a value for code 
frame cache physical pointer 100. In one embodi- 
ment, code frame cache directory 110 is organized 
to allow an 8-way set-associative search. 

Referring to FIG. 9, code frame cache directory 
110 includes, for example, sixteen rows and eight 
columns and each column and row intersection 
includes an entry 114. Each entry 114 includes a 
code frame address tag 116 and a state field 118. 
Code frame address tag 116 is. for example, the 
upper thirty-six bits of the 40-bit code frame point- 
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er 99 and is used in determining the address value 
of code frame cache physical pointer 100. State 
field 118 is a three-bit field used in indicating the 
state of a particular code frame 108 within code 
frame cache 88. A code frame within the code 
frame cache may have one of the following states: 

(a) An empty state which is defined by an un- 
successful attempt within a processing element 
to locate a particular code frame within the code 
frame cache. This state is proper when the code 
frame exists only in main storage or within an- 
other processing element. The empty state is 
recorded in the code frame cache at system 
initialization and whenever a code frame invali- 
dation occurs. 

(b) A transient state which applies to a code 
frame when it is in a state of motion. For exam- 
ple, the code frame is being moved from main 
storage to the code frame cache within the 
processing element (an inpage operation). Dur- 
ing inpaging, one of two possible transient 
states may be recorded for the frame, depend- 
ing on the desired final state of the code frame 
at inpage completion. The state is recorded as 
transient-final state, where final state may be the 
present state for a pretest/prefetch inpage 
(described below), or pinned for a 
pretest/prefetch inpage with invocation context 
map entry cache pinning control 37 as active. 
The transient state of a code frame in the code 
frame cache prevents selection of the code 
frame by a cache replacement algorithm, such 
as for example, a least recently used (LRU) 
algorithm, thereby allowing eventual completion 
of the inpage operation. 

(c) A present state which indicates that the con- 
tents of the desired code frame are entirely 
within code frame cache 88. When the code 
frame is in this state, then processing element 
14 may fetch the instructions located in code 
frame cache 88. 

(d) A pinned state which also indicates that the 
contents of the desired code frame are entirely 
within the code frame cache. However, if a code 
frame is marked as pinned, then replacement of 
the frame during pretest/prefetch is prevented 
(described below). In order to remove a pinned 
code frame from the cache, explicit software 
action is taken. 

Address tag 116 is used in conjunction with 
code frame pointer 99 to determine an address 
value for code frame cache physical pointer 100. In 
particular, the four rightmost bits of code frame 
pointer 99 (FIG. 8) are used to index into one of the 
rows within code frame cache directory 110. Sub- 
sequent to obtaining a particular row, the contents 
of each code frame cache address tag 116 within 
the selected row is compared against the value of 



bits 12-47 of code pointer 46. If a match is found, 
then the address value of the code frame cache 
physical pointer is obtained. In particular, the ad- 
dress of pointer 100 is equal to the row identifier 
5 (i.e.. the four rightmost bits of code frame pointer 
99) and column identifier, which is the binary repre- 
sentation of the column (i.e., columns 0-7) in which 
the match was found. 

Subsequent to determining code frame cache 
io physical pointer 100, the physical pointer is used in 
conjunction with code offset 105 located in local 
continuation queue 86 to locate an instruction 120 
within code frame 108. In order to select a particu- 
lar instruction 120 within code frame 108. code 
is frame cache physical pointer 100 is appended at 
122 on the left of code offset 105 located in local 
continuation queue entry 104. 

In one embodiment, instruction 120 includes 
the following fields which are loaded from the copy 
20 of code frame 22 located within main storage (the 
following fields are similar to the instruction fields 
described with reference to FIG. 4a, and therefore, 
some of the fields are not described in detail at this 
point): an operation code (OP CODE) 124, a thread 
25 control (TC) 125. an index increment control (X) 
127, a destination specifier 126, a source operand 
zero specifier 128 and a source operand one speci- 
fier 130. Destination specifier 126 indicates the 
address in which the result of the instruction execu- 
30 tion is to be written and the source operand specifi- 
ers indicate the addresses of the data operands 
located in local frame cache 90 to be read and 
used during execution of the instruction. 

Code frame cache 88 is coupled to local frame 
35 cache 90, as described in detail herein. Referring 
to FIGS. 10a, 10b, local frame cache 90 includes, 
for example. 256 local frames (131) and each 
frame includes 256 data words (132) (e.g., invoca- 
tion context queue information, destination location, 
40 source operands). In one embodiment, local frame 
cache 90 is organized into eight parallel word-wide 
banks. Each local frame 131 spans across all eight 
banks such that each bank stores thirty-two words 
of local frame 131. In one example, the first bank 
45 (bank 0) holds the following words of local frame 

131: word 0, 8. 16, 32. 40 248 (i.e., every 

eighth word of the local frame); the second bank 

(bank 1) holds words: 1. 9, 17. 33, 41 249 etc. It 

will be apparent to one of ordinary skill in the art 
so that this is only one way in which the local frame 
cache may be organized and the invention is not 
limited to such a way. Local frame cache 90 sup- 
ports two simultaneous access ports, a read port 
and a read/write port (not shown). The read port is 
55 used for fetching operands and the read/write port 
is used for storing results from instruction execu- 
tion and for deferring continuations, as described 
below. 



8 



BNSOOC1D: <£P 0565S49A2> 



15 



EP 0 565 849 A2 



16 



In one embodiment, the local frames located in 
local frame cache 90 are inpaged from main mem- 
ory control units 12 (i.e., datum 50 is inpaged) to 
local frame cache 90 during a prefetch stage, de- 
scribed below. In order to locate a local frame 
within the local frame cache (so that inpaged in- 
formation may be written to a location within the 
local frame or so that information may be read 
from a particular location), local frame pointer 96 
located in ready queue entry 94 is input into a local 
frame cache directory 133 in order to obtain an 
address value for local frame cache physical point- 
er 97 located in the ready queue entry. (In another 
embodiment, it is also possible to obtain the local 
frame cache physical pointer during pretesting 
(described below), thereby, eliminating the process 
for obtaining the pointer address from the cache 
directory.) In one embodiment, local frame cache 
directory 133 is organized in a similar manner to 
code frame cache directory 110, i.e., it is organized 
to allow an 8-way set-associative search. 

Referring to FIG. 1 1 , local frame cache direc- 
tory 133 includes, for example, thirty-two rows and 
eight columns and each column and row intersec- 
tion includes an entry 134. Each entry 134 includes 
a local frame address tag 136 and a state field 138. 
Local frame address tag 136 is, for example, the 
upper thirty-five bits of the 40-bit local frame point- 
er 96 and is used in determining the address value 
of local frame cache physical pointer 97, State field 
138 is a three-bit field used in indicating the state 
of a particular local frame 131 within local frame 
cache 90. A local frame within local frame cache 
may have one of the following states: 

(a) An empty state which is defined by an un- 
successful attempt within a processing element 
to locate a particular local frame within local 
frame cache 90. This state is valid for a local 
frame on the main storage free frame list and for 
one which resides entirely in main storage and 
is allocated to a process. The empty state may 
also be detected when a castout from the local 
frame cache to main storage is in progress for 
the referenced local frame, resulting in the ac- 
tual inpage being delayed until castout comple- 
tion. The empty state is recorded throughout 
local frame cache at system initialization and 
within local frame 131 in the cache whenever an 
attempted local frame inpage replacing a frame 
in cache is aborted. 

(b) A transient state which applies to a local 
frame when it is in a state of motion, e.g. mov- 
ing from main storage to the local frame cache 
(a local frame inpage). During the local frame 
inpage, the state of the inpaging frame is re- 
corded within local frame cache state 98. During 
inpage. one of the transient states is recorded 
for the frame depending upon the desired final 



state of local frame 131 at inpage completion. 
The final state may be present for a 
pretest/prefetch inpage (explained further below) 
or pinned for a pretest/prefetch inpage with in- 

5 vocation context map entry pinning control 37 

active. The transient state in the local frame 
cache prevents selection of local frame 131 by a 
local frame cache replacement algorithm (LRU), 
thereby allowing eventual completion of the in- 

/o page operation. This allows completion of any 
castout associated with the aborted inpage. 

(c) A free state which indicates a valid local 
frame in the local frame cache which is currently 
not allocated to any process. As one example, a 

is local frame enters this state through process 
termination. 

(d) A present state which indicates that the 
contents of local frame 131 are entirely within 
the local frame cache. When the local frame is 

20 within this state, the contents are available for 
access by an instruction within the processing 
element. 

(e) A pinned state which also indicates that the 
contents of the desired local frame are entirely 

25 within the local frame cache. However, if a local 
frame is marked as pinned, then replacement of 
the frame by pretest/prefetch is prevented 
(described below). In order to remove a pinned 
local frame from the cache, software action is to 

30 be taken. 

Address tag 136 is used in conjunction with 
local frame pointer 96 to determine the address 
value of local frame cache physical pointer 97. In 
particular, the five rightmost bits of local frame 

35 pointer 96 are used to index into one of the rows 
within local frame cache directory 133. Subsequent 
to obtaining a particular row, the contents of each 
local frame address tag 136 within the selected row 
is compared against the value of bits 13-47 of a 

40 logical local frame address (base address of the 
local frame in main storage). If a match is found, 
then the address value of local frame cache phys- 
ical pointer 97 is obtained. In particular, the ad- 
dress of the pointer is equal to the row identifier 

45 (i.e.. the five rightmost bits of local frame pointer 
96) and column identifier, which is the binary repre- 
sentation of the column (i.e., columns 0-7) in which 
the match was found. 

Subsequent to determining local frame cache 

so physical pointer 97, the physical pointer is used 
along with source operand 0 specifier 128 and 
index 106 (i.e.. the index is used if the addressing 
mode indicates that index addressing is to be 
used) to select a datum 132 from local frame 

55 cache 90 representative of a source operand 0 to 
be used during execution of an instruction. That is, 
a frame offset 140 of source operand 0 specifier 
128 (as previously described, each specifier in- 
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eludes an addressing mode (AM), state funct on 
?SR and frame offset) is added at 142 to ,ndex 106 
( h TJn loTal frame cache physical pointer 97 .s 
nded on he .Ttt of the summation to indicate 
dim (e. 9 -. source operand 0) within 

^ SIX -aMrame cache P-V^J^ 
is used with source operand 1 spec.f.er 130 and 
index 106 to select a datum 132 from local rame 
cache 90 representative of a source operand 1 also 
to be used during instruction execution. In part.cu- 
,ar. a frame offset 144 of source operand 1 spec- 
f,e 130 is added at 146 to index 106 and then, 
oca. frame cache physica. ^ 
on the left of the summation to md.cate a part.cuU 
datum (e.g.. source operand 1) w.th.n the local 

TJ'SSon to the above, -oca. frame cache 
physical pointer 97 is also used w,th dest.nat.on 
specifier 126 and index 106 (again, if the .ndex .s 
o P be used) to select a datum 132 from .oca. frame 
cache 90 representative of the locat.cn w.th.n the 
"ca, frame cache in which, e.g.. the resjtofthe 
instruction execute is to be stored. In , r^rt.cu.ar. a 
frame offset 147 of destinat.on spec.f.er 126 .s 
2£ at 149 to index 106 and then, .oca- frame 
cache physical po.nter 97 is appended on the left 
" the summation to indicate a part.cu.ar datum 
(e n a result location) within the local frame cache. 
( Associated with each datum stored .n .oca, 
frame cache 90 is a 3-bit state indicator 148 lo- 
cated in state bit cache 91. Similar to 'oca. frame 
cache 90. state bit cache 91 inc.udes. for examp.e_ 
256 locations (152) and each locat.on includes 256 
3-bit state indicators 148. In one embod.rnent state 
bit cache 91 is organized into eight word-w.de 
tanks accessib.e in para.lel. Each locat.on 152 
spans across a., eight banks such that eac , bank 
stores thirty-two words of locat.on 152. (The or 
ganization of the state bit cache .s s.m.lar to the 
organization of .oca. frame cache ». « 
in detail above.) .n accordance w.th the present 
invention, state indicators 148 are inpaged from 
main storage to state bit cache 91 (i.e state f.e.d 
28 of data entry 48 is copied) in parallel w.th the 
copying of datum 50 to local frame cache 90. 

The state bits are loaded into or read from the 
state bit cache in a manner similar to that de- 
scribed above for the local frame cache, m pajto- 
lar as shown in FIGS. 10a. 10b. each of the 
addresses obtained (e.g.. by appending the local 
frame cache physica. pointer on the .eft of he 
summation of the particular frame offset and the 
index, if needed) and used to select a datum 32 
(either a source operand or a dest.nat.on locat on) 
lorn local frame cache 90 is also used to select an 
associated state bit indicator 148 from state bit 
cache 91. Each state bit indicator 148 represents 



the current state of a particular datum. A P art.cular 
d*um and its associated state bit indicator are 
se.ected in P ara..e. from .oca. frame 
state bit cache 91. respectively, us.ng the process 
5 described above. However, it will be apparent to 
5 one ^ ordinary ski.. In the art that the state b.t 
cache may be organized in a number of ways and 
that only one embodiment, is desenbed herem it 
win a.so y be apparent to one of -ordinary .WNn *• 
,o art that it is also possible to el.m.nate the state brt 
cache and place the state bit indicators w.th.n he 
foca. frame cache, e.g.. adjacent to its assocated 

datU State bit indicators may have a number ot 
, 5 states (as one example, empty, waiting or present) 
and when an operand and an assocated state 
indicator are selected from .oca. frame cache 90 
and state bit cache 91. respecfvely. the next state 
for each selected operand is determ.ned. n add.- 
20 tion. when a result is to be written to a locat.on. the 
nerf state for that location is determ.ned. In one 
embodiment, in order to determine the next s ate of 
an operand or a result .ocation. a plurality of state 
LisUion tables and a state function assocated 
25 with each specifier is used. 

In particular, located in .nstruct.on 1 20 .s a 
state function 154 for destination specifier 126 a 
s ae faction 156 for source operand 0 specie 
128 and a state function 158 for source operand 1 
™ specifier 130. Each of the state funct.ons .s used to 
SSca e the synchronization function (desenbed 
ab ?v e ra sociaLd with its specific specifier and 
Sch state function is used as an address -nto a 
"ate transition table, -n one embodiment, there -s a 
35 state transition table for each spec.f.er That j 
here is a state transition tab.e 160 assocated w, h 
destination specifier 126. a state trans.fon table 
162 associated with source operand 0 spec.f.er 128 
and a state transition tab.e 164 assocated wrth 
«o source operand 1 specifier 130. Located w,th,n 
each of the state transition tables .s an en*y 165 
which includes the possible next states 166 fo 
each of the possible state functions. For example, .f 
state Unction 154 represents a synchroniz.no func- 
45 L of One-Time Producer. <*J^ 
then located within state trans.t.on tab.e 60 (state 
function 154 indexes into state trans.t.on table 160) 
s entry 165 including the possible next states for 
that synchronizing function. In one example each 
so entry may include eight possible next states. Fur- 
the if state function 154 could represent another 
Tynchronizing function, such as Multiple Producer 
Single Consumer, then there would be another 
enuy within state transition table 160 contam.ng , the 
55 possible next states for that synchrony , funcfon. 
Similarly state transition tables 162 and 164 .n- 
lde 7ntries 165 which contain the ^ *e« 
states 166. Each state transition table .s. e.g. Ic- 
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cated within processing element 14 and may be 
statically altered at system initialization in any 
known manner to include additional entries of next 
states which support further synchronizing func- 
tions. 

As shown in FIG. 10b. associated with each 
next state 166 is a 3-bit control flag 168. Control 
flag 168 is set at system initialization and is fixed 
for its associated next state. Control flag 168 is 
used in indicating to the processing element which 
action is to be taken for the thread which includes 
instruction 120. That is. control flag 168 indicates, 
for instance, whether execution of the thread is to 
be continued or whether execution is to be de- 
ferred (explained below). 

Referring to FIG. 12, in operation, a process to 
be executed is dispatched by interconnection net- 
work 18 to one of processing elements 14, STEP 
180 "Dispatch Process." Subsequent to receiving 
the dispatched process, a decision is made within 
the processing element as to whether the process 
is to be placed on the invocation context queue 
located within the main memory control unit which 
is associated with the particular processing element 
or on ready queue 84 located within the processing 
element, STEP 182 "Determine Where to Place 
Incoming Process." 

In particular, in deciding where to place the 
process, an initial inquiry is made as to whether the 
process is to be enqueued on ready queue 84 in a 
first in-first out manner, INQUIRY 184 "Process 
Enqueued FIFO?" Should the process be en- 
queued in a first in-first out manner, then a check 
is made to see if the ready queue is full and 
therefore, cannot accept any more processes, IN- 
QUIRY 186 "Ready Queue Full?" If the ready 
queue is full, the process is placed onto the tail 
end of the invocation context queue in main stor- 
age until a position is available in the ready queue, 
STEP 188 "Enqueue onto ICQ." When placing a 
process on the tail of the invocation context queue, 
invocation context queue backward pointer 44 lo- 
cated within invocation context map entry 26 of the 
process being added is replaced with the current 
value of the invocation context queue tail. In addi- 
tion, invocation context queue forward pointer 42 of 
the last process identified by the old tail is updated 
to indicate the new tail of the invocation context 
queue, which is equal to the local frame pointer of 
the process being added. Further, the invocation 
context queue tail is set equal to the local frame 
pointer of the process being added, STEP 189 
"Update ICQT and ICQH." 

Returning to INQUIRY 186, if, however, the 
ready queue is not full, then the process is added 
to the tail end of ready queue 84, STEP 190 
"Enqueue onto the Ready Queue." In addition to 
loading the process onto the ready queue, one or 
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more threads associated with the process, are en- 
queued onto local continuation queue 86, STEP 
191 "Place Thread on LCQ." Subsequently, in or- 
der to indicate that there are valid entries in the 
s local continuation queue for the process on the 
ready queue, local continuation queue head 38 and 
tail 40 are copied from invocation context queue 26 
to local continuation queue head 102 and tail 103 
located in ready queue entry 94 designated for that 
w process. 

When a process is placed on the ready queue, 
ready queue state 95 located within ready queue 
entry 94 is updated from empty to pending pretest. 
STEP 192 "RQ State is Updated." 
is Referring back to INQUIRY 184, should a pro- 

cess be enqueued onto ready queue 84 in a last 
in-first out fashion, then the process is enqueued 
onto the head of the ready queue with the possibil- 
ity of replacing a valid ready queue entry 94 at the 
20 tail of the ready queue, STEP 190 "Enqueue onto 
Ready Queue." Once again when the process is 
added to the ready queue, threads for that process 
are placed on local continuation queue 86, STEP 
191 "Place Thread on LCQ" and ready queue state 
25 95 is updated to pending pretest, STEP 192 "RQ 
State is Updated." The replaced valid entry may be 
castout to the head of the invocation context queue 
in main storage. When adding to the head of the 
invocation context queue, invocation context queue 
30 forward pointer 42 for the new process is updated 
to point to the old head of the invocation context 
queue. In addition, invocation context queue back- 
ward pointer 44 of the old head is updated to point 
to the process being added (using local frame 
35 pointer). Further, the invocation context queue head 
is updated to point to the new process represented 
by the local frame pointer. Also, local continuation 
queue head 102 and tail 103 are copied from ready 
queue entry 94 to local continuation queue head 38 
40 and tail 40 in invocation context map entry 26. 

As previously mentioned, when a process is 
added to the ready queue, the state of the ready 
queue entry is updated from empty to pending 
pretest. During pending pretest, the availability of 
45 the resources required for execution of the process 
is determined. INQUIRY 194 "Are Resources Avail- 
able?" In particular, code frame cache 88 is 
checked to see whether code frame 108 as in- 
dicated by code frame pointer 99 in ready queue 
50 entry 94 is located within the code frame cache. 
Similarly, local frame cache 90 is checked to deter- 
mine if local frame 131 as indicated by local frame 
pointer 96 in ready queue entry 94 is located within 
the local frame cache. Should it be determined that 
55 code frame 108 or local frame 131 is not present 
within its respective cache and. therefore, is not 
available to the process during processing, the 
missing code frame and/or local frame is inpaged 
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from main storage and thereby made available, 
STEP 196 "Prefetch Resources." In particular, 
code frame 108 is copied from code frame 22 in 
main storage to code frame cache 88 (inpaging). 
Further, local frame 131 is copied from datum 50 
located within local frame 20 in main memory 
control units 12 to local frame cache 90 and in 
parallel, state indicator 28 which is associated with 
the datum is inpaged from main memory control 
units 12 (i.e.. local frame 20) to state bit cache 91. 
The moving of data between main memory control 
units and one or more caches allows for the num- 
ber of processes and threads which can be ex- 
ecuted by the processing element to be bound 
only by the size of main storage and not by a finite 
amount of local storage. During inpaging. ready 
queue state 95 is updated from pending pretest to 
prefetch active, STEP 198 "Update RQ State." 

Subsequent to inpaging the resources during 
prefetch or if an affirmative response is obtained 
from INQUIRY 194, ready queue state 95 is up- 
dated from prefetch active to ready indicating that 
the process is ready for execution by the process- 
ing element. STEP 200 "Update RQ State." A 
ready process may be executed by the processing 
element when the process is. for example, the top 
entry in ready queue 84. When the top entry is 
selected for execution, the top thread located in 
local continuation queue 86 is selected, STEP 202 
"Select Process and Thread. 1 * When this occurs, 
ready queue state 95 is updated from ready to 
running, STEP 204 "Update RQ State." In addition, 
the state of the previous running ready queue entry 
is changed from running to empty, ready or sleep- 
ing (all of which are described above) depending 
on the conditions for which it relinquishes control of 
processing within the processing element. 

The selected thread (or local continuation 
queue entry 104) from local continuation queue 86 
includes code offset 105 which is used, as de- 
scribed above, in selecting an instruction 120 from 
code frame cache 88 to be executed, STEP 206 
"Fetch Instruction." When instruction 120 is 
fetched, local continuation queue head pointer 102 
located in ready queue entry 94 is adjusted to 
indicate the removal of the processing thread from 
the local continuation queue, STEP 208 "Adjust 
LCQ Head." 

As described above, the instruction which is 
selected includes source operand 0 specifier 128 
which is used to select datum 132 representative of 
a source operand 0 from local frame cache 90 and 
its associated state bit 148 from state bit cache 91. 
Also, source operand 1 specifier 130 is used to 
select datum 132 representative of a source 
operand 1 from local frame cache 90 and its asso- 
ciated state bit 148 located in state bit cache 91. 
STEP 210 "Select Data and State Bits." 



In addition to the above, state functions 156 
and 158 located in source operand 0 specifier 128 
and source operand 1 specifier 130, respectively 
are used in selecting a number of possible next 
5 states 166 from state transition tables 162. 164. In 
particular, state function 156 is used as an address 
into state transition table 162 to select entry 165 
which includes the next states for source operand 0 
specifier. Similarly, state function 158 is used as an 
io address into state transition table 164 to select 
entry 165 which includes the next states for source 
operand 1 specifier. STEP 212 "Select Possible 
Next States." (As-described above, each state 
function is representative of a synchronizing func- 
75 tion and the states associated with each synchro- 
nizing function are included in the state transition 
tables.) 

Subsequent to selecting the possible next 
states for a source operand, the current state (state 
20 indicator 148) of the operand is used in choosing 
one state from the possible next states which re- 
presents the next state for that operand. For exam- 
ple, if there are eight next states (0-7) and the 
value of state bit indicator 148 is zero, then the 
25 next state for state indicator 148 is the state lo- 
cated at position 0 of the eight next states (i.e.. 
column 0 or the first next state out of the eight 
states), STEP 214 "Determine Next State." In one 
embodiment, for a particular synchronizing func- 
30 tion, it may be that state bit indicator 148 repre- 
sents a present state for an operand which has 
been read and the possible next states for a par- 
ticular synchronizing function are empty, waiting 
and present. In one example, the next state to be 
35 selected for that operand is the present state. After 
the next state is determined, state indicator 148 is 
updated to the value of the next state, e.g.. by 
writing the value of the next state into the current 
state value located in state bit cache 91, STEP 216 
40 "Update Current State." 

In addition to the above, a determination is 
made as to the course of action to be taken by the 
thread which includes the instruction being ex- 
ecuted. STEP 218 "Determine Action to be Taken." 
45 Types of actions which may be taken include, for 
instance, continue with thread execution, suspend 
current thread and awaken deferred thread, each of 
which are explained below. 

In one embodiment, in order to determine what 
so action is to be taken by the thread, an inquiry is 
made into whether the data (e.g.. source operand 0 
and/or source operand 1) located in local frame 
cache 90 and selected by executing instruction 120 
is available for use by the instruction, INQUIRY 220 
55 w ls Data Available?" In particular, this determination 
is made by checking state indicator 148 (bsfore it 
is updated to the next state) associated with each 
of source operands 0 and 1 . Should state indicator 
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148 indicate, for instance, that an operand is in an 
empty state, then that operand is considered un- 
available. If. however, state indicator 148 indicates 
that each operand is in, for example, a present 
state, then the operands are considered available. 
If the data is available, then execution of the thread 
continues and the result of the executing instruction 
is stored in a result location within local frame 
cache 90. STEP 222 "Continue Execution." as de- 
scribed in detail herein. 

In one example, instructions are executed with- 
in execution unit 92, which is coupled to local 
frame cache 90 within processing element 14. Ad- 
dressing mode 78 of each source operand specifier 
located in instruction 120 gates the appropriate 
data, such as source operand 0 and source 
operand 1 (which has been obtained as described 
above), into input registers (not shown) of execu- 
tion unit 92. Execution unit 92 executes the instruc- 
tion using the obtained operands and places the 
result in a destination (or result) location located 
within local frame cache 90 indicated by destina- 
tion specifier 126 of instruction 120. If. however, 
the result of the instruction execution is a branch to 
a specific location, then a new thread (in particular, 
a new compressed continuation descriptor) may be 
enqueued onto local continuation queue 86 (if the 
thread is for the same process that is currently 
being executed) or a new thread may be handled 
by interconnection network 18 and enqueued onto 
a different process' local continuation queue. 

On the other hand, if the answer to INQUIRY 
220 is in the negative and one or more of the 
source operands are not available (e.g.. the state 
indicator associated with that operand indicates the 
operand is not in a present state), then execution of 
the thread associated with the executing instruction 
is deferred. STEP 224 "Defer Execution of 
Thread." (In one example, the particular instruction 
continues executing, but the results are not stored.) 
In particular, if source operand 0 or source operand 
1 is in, for example, a state of empty or waiting and 
therefore, unavailable (if both operands are unavail- 
able, then in one embodiment, operand zero is 
preferred over operand one), then the thread cur- 
rently executing (represented by code offset 105 
and index 106 in local continuation queue entry 
104 within local continuation queue 86) is sus- 
pended until source operand 0 and source operand 
1 (if both are needed) are available. When suspen- 
sion occurs, any affects of the instruction are nulli- 
fied. 

In order to suspend execution of a thread, code 
offset 105 and index 106 (also referred to as the 
compressed continuation descriptor) located within 
the local continuation queue are stored in the da- 
tum location (or field) representative of the unavail- 
able source operand. Each datum 132 may receive 



a number of compressed continuation descriptors 
corresponding to a number of threads. In one ex- 
ample, each datum may store four compressed 
continuation descriptors, 
s When data is to be written to a datum location 

132 within local frame cache 90, the result location 
and its associated state indicator are specified, as 
described in detail above, by frame offset 147 of 
destination specifier 126 located within code frame 
to cache 88. local frame cache physical pointer 97 
and any corresponding index 106, STEP 226 "Data 
is to be Written" (FIG. 13) In addition to selecting 
the location and the state indicator, state function 
154 located in destination specifier 126 is used as 
75 an address into state transition table 160 to select 
a number of possible next states 166 for the result 
location (similar to the procedure described above 
for selecting the next state for the source 
operands). As described above, subsequent to se- 
20 lecting the possible next states for the result loca- 
tion, the current state indicator 148 for that location 
is used to choose the next state for the location. 
The current state indicator is then updated to re- 
flect the value of the next state. 
25 In addition to the above, a determination is 

made as to whether the result location is empty, 
INQUIRY 228 "Is Location Empty?" (When data is 
to be written, a read/write port is used, since the 
location is initially read to determine if anything is 
30 stored there before data is written to the location.) 
Should chosen datum 132 be empty (as indicated 
by state indicator 148 before it is updated to the 
next state), then the data is written to that location. 
STEP 230 "Write Data." On the other hand, if the 
35 location is not empty, a determination is made as 
to whether there is one or more compressed con- 
tinuation descriptors stored within the location and, 
therefore, the location is in a waiting state (again, 
as indioated by state indicator 148), STEP 231 "Is 
40 Location in Waiting State?" If the location is not in 
the waiting state, then the data is written, STEP 
234 "Write Data." If. however, that location is in a 
waiting state, then any and all compressed continu- 
ation descriptors, stored in that location are re- 
45 moved and enqueued onto the local continuation 
queue associated with the running process before 
the data is written, STEP 232 "Awaken Com- 
pressed Continuation Descriptors." Subsequent to 
removing the compressed continuation descriptors, 
so the data is written to the indicated location, STEP 
234 "Write Data." 

In one specific embodiment, each next state 
resident within state transition tables 160, 162. 164 
has an associated 3-bit control flag 168 which is 
55 retrieved when the possible next states are re- 
trieved. When one of the next states is selected, as 
described above, the associated control flag 168 is 
also selected and is used to indicate what action is 
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to be taken by the processing element. That is. the 
control flag indicates, for example, whether thread 
execution is to be continued, whether execution of 
the thread is to be deferred or whether a deferred 
thread is to be awakened. Each of these actions is 
performed in the manner described above. 

Although preferred embodiments have been 
depicted and described in detail herein, it will be 
apparent to those skilled in the relevant art that 
various modifications, additions, substitutions and 
the like can be made without departing from the 
spirit of the invention and these are therefore con- 
sidered to be within the scope of the invention as 
defined in the following claims. 

Claims 

1. A method for synchronizing execution by a 
processing element of threads within a pro- 
cess, said method comprising the steps of: 
executing a thread within a process; 
fetching during said thread execution from a 
local frame cache a datum field; 
fetching from a state bit cache a state indica- 
tor, said state indicator being associated with 
said datum field and having a first state value; 
determining based on said first state value 
whether said datum field includes a datum 
available for use by said thread; and 
deferring execution of said thread when said 
datum is unavailable. 

2. The method of claim 1, further including the 
step of determining a second state for said 
state indicator, said second state replacing 
said first state during said thread execution. 

3. The method of claim 2, wherein said second 
state determining step includes the steps of: 
selecting from said thread a state function to 
be used in determining said second state; 
using said state function to select from one of 
a plurality of tables N possible second states 
for said indicator; and 

using said first state to choose from said se- 
lected N possible states said second state for 
said indicator. 

4. The method of claim 3. wherein said first state 
represents a current state of said datum and 
said second state represents a next state of 
said datum. 

5. The method of one of claims 1 to 4. wherein 
said thread is represented by a continuation 
descriptor and said deferring step includes the 
step of storing said continuation descriptor 
within said datum field. 



6. The method of claim 5. wherein said continu- 
ation descriptor is compressed before being 
stored in said datum field and said datum field 
can receive a plurality of said compressed 

5 continuation descriptors. 

7. The method of claim 6, further including the 
step of awakening said deferred thread when 
datum is available for said thread. 

o 

8. The method of claim 7, wherein said awaken- 
ing step includes the step of removing said 
compressed continuation descriptors from said 
datum field. 

is 

9. The method of claim 8, wherein said removed 
continuation descriptors are stored on a queue 
local to said processing element. 

20 10. The method of claim 8 or 9. wherein said 
awakening step further includes the step of 
storing said available datum in said datum field 
when said compressed continuation descrip- 
tors are removed. 

11. A system for synchronizing execution by a 
processing element of threads within a pro- 
cess, said system comprising: 
a local frame cache, said local frame cache 
30 including a datum field; 

a state bit cache, said state bit cache including 
a state indicator corresponding to said datum 
field; 

means for executing by said processing ele- 

35 ment a thread within a process; 

means for fetching from said local frame cache 
said datum field and from said state bit cache 
said state indicator having a first state value; 
means for determining based on said first state 

40 value whether said datum field includes a da- 

tum available for use by said thread; and 
means for deferring execution of said thread 
when said datum is unavailable. 

45 12. The system of claim 11. further comprising 
means for determining a second state for said 
state indicator, said second state replacing 
said first state during said thread execution. 

so 13. The system of claim 12. wherein said second 
state determining means comprises: 
means for selecting from said thread a state 
function to be used in determining said second 
state; 

55 a plurality of tables each having N possible 

second states for said indicator; 
means for using said state function to select 
from one of said plurality of tables said N 
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possible second states; and 
means for using said first state to choose from 
said selected N possible states said second 
state for said indicator. 

14. The system of claim 13, further comprising a 
main storage, said main storage comprising a 
copy of said datum field and a copy of said 
state indicator, said copy of said datum field 
being copied from main storage to said local 
frame cache and said copy of said state in- 
dicator being copied from said main storage to 
said state bit cache. 

15. A method for synchronizing execution by a 
processing element of threads within a pro- 
cess, each of said threads including a plurality 
of instructions, said method comprising the 
steps of: 

executing an instruction of said thread; 
fetching during said instruction execution from 
a local frame cache at least one source 
operand and from a state bit cache at least 
one state indicator having a first state value, 
said at least one state indicator corresponding 
to said at least one source operand; 
fetching from said instruction at least one state 
function associated with said at least one 
fetched source operand; 

using said at least one state function to select 
from one of a plurality of tables N possible 
second states for said at least one state indica- 
tor, each of said second states having a cor- 
responding flag indicator; 

using said first state to choose from said se- 
lected N possible states a second state for 
said state indicator; 

replacing said first state with said second state 
during said thread execution; and 
having said thread perform one of a plurality of 
actions after said instruction execution, said 
action being specified by said flag indicator 
associated with said chosen second state. 

16. The method of claim 15, wherein said plurality 
of actions includes the following actions: con- 
tinuing execution of said thread, deferring ex- 
ecution of said thread and awakening a de- 
ferred thread. 

17. The method of claim 16. wherein said thread is 
represented by a continuation descriptor and 
said deferring execution action includes the 
step of storing said continuation descriptor 
within a source operand. 

18. The method of claim 17, wherein said continu- 
ation descriptor is compressed before being 
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stored and said source operand can receive a 
plurality of compressed continuation descrip- 
tors. 

s 19. The method of claim 18. wherein said awaken- 
ing action includes the step of removing a 
compressed continuation descriptor from a 
source operand. 

w 20. The method of claim 19, wherein said awaken- 
ing action further includes the step of storing a 
source operand when said compressed con- 
tinuation descriptor is removed. 

75 21. The method of claim 20, wherein said removed 
continuation descriptor is stored on a queue 
local to said processing element. 

22. A system for synchronizing execution by a 
20 processing element of threads within a pro- 

cess, each of said threads including a plurality 
of instructions, said system comprising: 
means for executing an instruction of said 
thread; 

25 a local frame cache, said local frame cache 

including a plurality of source operands; 
a state bit cache, said state bit cache including 
a plurality of state indicators, each of said state 
indicators having a first state value, and 

30 wherein one of said state indicators corre- 

sponds to one of said source operands; 
means for fetching during said instruction ex- 
ecution from said local frame cache at least 
one source operand and from said state bit 

as cache at least one corresponding state indica- 

tor; 

means for fetching from said instruction at 
least one state function associated with said at 
least one source operand; 

40 a plurality of tables each having N possible 

second states for each of said state indicators; 
means for using said at least one state function 
to select from one of said plurality of tables 
said N possible second states, each of said 

45 second states having an associated flag indica- 

tor; 

means for using said first state to choose from 
said selected N possible states a second state 
for said state indicator; 
so means for replacing said first state with said 

second state; and 

means for having said thread perform one of a 
plurality of actions, said action being specified 
by said flag indicator associated with said cho- 
55 sen second state. 
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© A method and system for synchronizing threads within a process. 

execution and the data is stored in the location. 



© A method and system is described for synchro- 
nizing execution by a processing element of threads 
within a process. Before execution of a thread com- 
mences, a determination is made as to whether all of 
the required resources for execution of the thread 
are available in a cache local to the processing 
element. If the resources are not available, then the 
resources are fetched from main storage and stored 
in one or more local caches before execution begins. 
If the resources are available, then execution of the 
thread may begin. During execution of the thread 
and, in particular, an instruction within the thread, the 
instruction may require data in order to successfully 
complete its execution. When this occurs, a deter- 
mination is made as to whether the necessary data 
is available. If the data is available, the result of the 
instruction execution is stored and execution of the 
thread continues. However, if the data is unavailable, 
then the thread is deferred until the data becomes 
available and a new thread is processed. When 
deferring a thread, the thread is placed in the mem- 
ory location which is to receive the required data. 
Once the data is available, the thread is removed 
from the data location and placed on a queue for 
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